*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#0b0b0e;--surface:#131318;--card:#1a1a22;--card2:#21212c;
  --border:#29293a;--border2:#363648;
  --accent:#e8b800;--accent-glow:rgba(232,184,0,.12);--accent-dim:#7a6100;
  --red:#dc3545;--green:#2ea043;--blue:#58a6ff;--orange:#f97316;
  --go:#f59e0b;--go-bg:rgba(245,158,11,.07);
  --gi:#10b981;--gi-bg:rgba(16,185,129,.07);
  --text:#dddde8;--text2:#8888a0;--text3:#44444f;
  --hol-bg:#191200;--today-bg:#0d1a2a;
  --r:6px;--r2:10px;--r3:14px;
}
html,body{background:var(--bg);color:var(--text);font-family:'Outfit',system-ui,sans-serif;height:100vh;overflow:hidden;}
#main-app{display:none;height:100vh;flex-direction:column;}
input,select,textarea{font-family:inherit;}
::-webkit-scrollbar{width:5px;height:5px;}::-webkit-scrollbar-track{background:var(--bg);}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* ── HEADER ─────────────────────────────── */
.hdr{display:flex;align-items:center;gap:10px;padding:9px 14px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;}
.brand{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.brand-icon{font-size:20px;line-height:1;}
.brand-name{font-size:13px;font-weight:700;color:var(--text);}
.fil-edit{display:flex;align-items:center;gap:5px;background:var(--card);border:1px solid var(--border2);border-radius:20px;padding:3px 10px 3px 8px;cursor:pointer;transition:border-color .15s;}
.fil-edit:hover{border-color:var(--accent);}
.fil-num{font-size:12px;font-weight:700;color:var(--accent);font-family:'JetBrains Mono',ui-monospace,monospace;}
.fil-edit-icon{font-size:10px;color:var(--text3);}
.week-nav{display:flex;align-items:center;gap:6px;margin:0 auto;}
.nav-btn{width:26px;height:26px;background:var(--card);border:1px solid var(--border2);color:var(--text);border-radius:var(--r);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .15s;}
.nav-btn:hover{background:var(--card2);}
.week-info{text-align:center;min-width:140px;}
.kw-lbl{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:1px;}
.dr-lbl{font-size:11px;color:var(--text2);margin-top:1px;}
.today-btn{font-size:10px;padding:2px 8px;background:none;border:1px solid var(--border2);color:var(--text2);border-radius:20px;cursor:pointer;transition:all .15s;}
.today-btn:hover{border-color:var(--accent);color:var(--accent);}
.hdr-actions{display:flex;gap:5px;flex-shrink:0;flex-wrap:wrap;}
.btn{padding:5px 11px;background:var(--card);border:1px solid var(--border2);color:var(--text);border-radius:var(--r);cursor:pointer;font-size:12px;font-family:inherit;transition:all .15s;}
.btn:hover{background:var(--card2);}
.btn-y{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700;}
.btn-y:hover{background:#ffd000;}
.btn-or{background:rgba(249,115,22,.12);border-color:rgba(249,115,22,.35);color:var(--orange);}
.btn-or:hover{background:rgba(249,115,22,.22);}
.btn-sm{padding:4px 9px;font-size:11px;}

/* ── TABLE ──────────────────────────────── */
.sched-wrap{overflow-x:auto;overflow-y:hidden;flex:1;min-height:0;display:flex;flex-direction:column;}
table.sched{border-collapse:collapse;width:100%;height:100%;table-layout:fixed;}
.sched th,.sched td{border:1px solid var(--border);vertical-align:top;}
td.day-col,th.day-th{width:86px;background:var(--surface);position:sticky;left:0;z-index:2;}
thead th{position:sticky;top:0;z-index:3;background:var(--card);}
thead th.day-th{z-index:4;}
.sched tbody{height:100%;}
.sched tbody tr{height:calc(100% / 6);}
.sc{padding:6px 8px;cursor:pointer;width:100%;height:100%;box-sizing:border-box;transition:background .1s;position:relative;overflow:hidden;}
.emp-th{overflow:hidden;}
.emp-hdr{padding:7px 9px;overflow:hidden;}
.emp-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:116px;}
.emp-role{font-size:10px;color:var(--text2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:116px;}
.emp-badges{display:flex;gap:3px;margin-top:3px;flex-wrap:wrap;}
.badge{display:inline-block;font-size:9px;font-weight:700;padding:1px 5px;border-radius:10px;text-transform:uppercase;}
.badge-vz{background:rgba(74,158,255,.15);color:var(--blue);}
.badge-tz{background:rgba(40,167,69,.15);color:var(--green);}
.badge-gfb{background:rgba(232,184,0,.1);color:var(--accent);}
.badge-rk{background:rgba(220,53,69,.1);color:var(--red);}
.badge-neutral{background:rgba(136,136,160,.12);color:var(--text2);}
th.div-col,td.div-col{width:4px;min-width:4px;padding:0;background:var(--border2)!important;border:none;}
.sc{padding:6px 8px;cursor:pointer;transition:background .1s;position:relative;overflow:hidden;}
.sc:hover{background:var(--card2)!important;}
.st{font-size:12px;font-weight:600;font-family:'JetBrains Mono',ui-monospace,monospace;}
.sh{font-size:10px;color:var(--green);margin-top:2px;font-weight:700;}
.sp{font-size:10px;color:var(--text3);margin-top:1px;}
.sn{font-size:10px;color:var(--accent);margin-top:2px;font-style:italic;word-break:break-word;}
.sc.go-c{background:var(--go-bg);}
.sc.gi-c{background:var(--gi-bg);}
.go-b{display:inline-block;font-size:9px;font-weight:700;background:rgba(245,158,11,.18);color:var(--go);border:1px solid rgba(245,158,11,.3);padding:2px 7px;border-radius:10px;margin-bottom:3px;}
.gi-b{display:inline-block;font-size:9px;font-weight:700;background:rgba(16,185,129,.18);color:var(--gi);border:1px solid rgba(16,185,129,.3);padding:2px 7px;border-radius:10px;margin-bottom:3px;}
.se{color:var(--text3);height:48px;display:flex;align-items:center;justify-content:center;font-size:18px;opacity:0;transition:opacity .15s;}
.sc:hover .se{opacity:.45;}
.copy-btn{position:absolute;top:3px;right:3px;background:none;border:none;color:var(--text3);font-size:11px;cursor:pointer;padding:2px 4px;border-radius:3px;opacity:0;transition:opacity .15s;line-height:1;z-index:2;}
.sc:hover .copy-btn{opacity:.6;}
.copy-btn:hover{opacity:1!important;color:var(--accent);background:rgba(232,184,0,.1);}
.sc.copy-source{outline:2px solid var(--accent);outline-offset:-2px;}
.sc.copy-source .copy-btn{opacity:1;color:var(--accent);}
.sc.copy-target-hover{outline:2px dashed var(--gi);outline-offset:-2px;}
.frei-line{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.frei-line svg{width:100%;height:100%;}
.sc.bs-c{background:rgba(88,166,255,.04);}
.sh-early-txt{color:var(--accent)!important;font-weight:700!important;}
.sh-late-txt{color:var(--blue)!important;font-weight:700!important;}
.sh-mixed-txt{color:var(--orange)!important;font-weight:700!important;}
.hol-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:10px;font-weight:700;pointer-events:none;}
tfoot td{background:var(--surface);padding:5px 8px;border-top:2px solid var(--border2);}
.tot-lbl{font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;}
.tot-h{font-size:13px;font-weight:700;font-family:'JetBrains Mono',ui-monospace,monospace;margin-top:2px;}
.over{color:var(--red)!important;}.near{color:var(--accent)!important;}.under{color:var(--green)!important;}

/* ── FOOTER ─────────────────────────────── */
.footer{display:flex;align-items:center;gap:12px;padding:5px 14px;background:var(--surface);border-top:1px solid var(--border);font-size:11px;color:var(--text2);flex-wrap:wrap;}
.footer select{background:var(--card);border:1px solid var(--border);color:var(--text);padding:2px 6px;border-radius:4px;font-size:11px;font-family:inherit;margin-left:4px;}
.save-lbl{font-size:10px;color:var(--green);margin-left:auto;}
.sync-b{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600;cursor:pointer;border:1px solid;transition:all .15s;}
.sync-on{background:rgba(16,185,129,.12);color:var(--gi);border-color:rgba(16,185,129,.3);}
.sync-off{background:rgba(88,101,242,.1);color:#7289da;border-color:rgba(88,101,242,.3);}
.sync-none{background:var(--card2);color:var(--text3);border-color:var(--border);}

/* ── MODALS ─────────────────────────────── */
.mwrap{position:fixed;inset:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;}
.mbox{background:var(--card);border:1px solid var(--border2);border-radius:var(--r2);padding:18px 20px;width:100%;max-width:370px;max-height:92vh;overflow-y:auto;}
.mtitle{font-size:14px;font-weight:700;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;}
.mclose{background:none;border:none;color:var(--text2);cursor:pointer;font-size:18px;line-height:1;padding:0;}
.fld{margin-bottom:10px;}
.fld label{display:block;font-size:10px;font-weight:700;color:var(--text2);margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px;}
.fld input,.fld select{width:100%;background:var(--card2);border:1px solid var(--border2);color:var(--text);padding:7px 9px;border-radius:var(--r);font-size:13px;}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--accent);}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.mbtns{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap;}
.spacer{flex:1;}
.btn-red{background:rgba(220,53,69,.12);border-color:rgba(220,53,69,.3);color:var(--red);}
.btn-red:hover{background:rgba(220,53,69,.22);}
.go-box{margin-top:10px;padding:9px;background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.18);border-radius:var(--r);}
.go-box-title{font-size:10px;font-weight:700;color:var(--go);margin-bottom:6px;}
.tlbl{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text2);cursor:pointer;margin-bottom:6px;}
.tlbl input{accent-color:var(--go);}

/* ── OVERLAY ─────────────────────────────── */
.owrap{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:22px 14px;overflow-y:auto;}
.pbox{background:var(--card);border:1px solid var(--border2);border-radius:var(--r2);padding:18px 20px;width:100%;max-width:500px;position:relative;}
.phdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:13px;}
.ptitle{font-size:14px;font-weight:700;}
.slbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin:10px 0 7px;}
.ei{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--card2);border-radius:var(--r);margin-bottom:4px;border:1px solid var(--border);}
.ei.gi-item{border-color:rgba(16,185,129,.25);background:rgba(16,185,129,.04);}
.ei-info{flex:1;min-width:0;}
.ei-name{font-size:13px;font-weight:600;}
.ei-meta{font-size:10px;color:var(--text2);margin-top:1px;}
.ei-tgt{font-size:10px;margin-top:2px;}
.btn-ic{background:none;border:none;color:var(--text3);cursor:pointer;font-size:13px;padding:3px 5px;border-radius:4px;transition:all .15s;}
.btn-ic:hover{color:var(--red);}
.btn-ic.edit:hover{color:var(--blue);}
.af{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:3px;}
.af input,.af select{background:var(--card2);border:1px solid var(--border2);color:var(--text);padding:6px 8px;border-radius:var(--r);font-size:12px;}
.af-r{display:grid;grid-template-columns:1fr auto;gap:6px;margin-top:6px;}
.gaf{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-top:3px;}
.gaf input,.gaf select{background:var(--card2);border:1px solid var(--border2);color:var(--text);padding:6px 8px;border-radius:var(--r);font-size:12px;}
.gaf-r{display:grid;grid-template-columns:1fr 1fr auto;gap:6px;margin-top:6px;}
.gaf-r input{background:var(--card2);border:1px solid var(--border2);color:var(--text);padding:6px 8px;border-radius:var(--r);font-size:12px;}
.ic-box{display:none;position:absolute;inset:0;background:rgba(0,0,0,.7);border-radius:var(--r2);align-items:center;justify-content:center;z-index:10;}
.ic-inner{background:var(--card);border:1px solid var(--border2);border-radius:var(--r2);padding:18px 20px;max-width:290px;width:90%;}
#import-err{display:none;font-size:11px;color:var(--red);background:rgba(220,53,69,.1);border:1px solid rgba(220,53,69,.22);border-radius:var(--r);padding:6px 9px;margin-top:7px;}

/* Discord / WA */

.dtip{background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.28);border-radius:var(--r);padding:10px 13px;margin-top:10px;}
.sync-b.sync-lock{background:rgba(232,184,0,.12);color:var(--accent);border-color:var(--accent-dim);}
.archive-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:var(--r);font-size:11px;border:0.5px solid var(--border);margin-bottom:3px;background:var(--card2);}
.archive-row.locked{border-color:rgba(232,184,0,.3);background:rgba(232,184,0,.06);}
.archive-kw{font-weight:700;color:var(--accent);min-width:44px;font-family:'JetBrains Mono',ui-monospace,monospace;}
.archive-date{color:var(--text2);flex:1;}
.archive-count{font-size:10px;color:var(--text3);}
.past-warn{display:none;font-size:11px;padding:7px 9px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);border-radius:var(--r);margin-top:8px;color:var(--go);line-height:1.6;}
.dtip h3{font-size:11px;font-weight:700;color:#7289da;margin-bottom:5px;}
.dtip ol{padding-left:14px;font-size:11px;color:var(--text2);line-height:1.9;}
.copy-ok{font-size:12px;color:var(--green);margin-left:6px;display:none;}


/* Setup modal */
#setup-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;}
.setup-card{background:var(--card);border:1px solid var(--border2);border-radius:var(--r3);padding:32px 28px;width:100%;max-width:340px;text-align:center;}
.setup-icon{font-size:36px;margin-bottom:14px;}
.setup-title{font-size:18px;font-weight:700;margin-bottom:6px;}
.setup-sub{font-size:12px;color:var(--text2);margin-bottom:22px;line-height:1.6;}
.setup-inp{width:100%;background:var(--card2);border:1px solid var(--border2);color:var(--text);padding:10px 12px;border-radius:var(--r);font-size:16px;text-align:center;letter-spacing:2px;font-family:'JetBrains Mono',ui-monospace,monospace;}
.setup-inp:focus{outline:none;border-color:var(--accent);}
.setup-btn{width:100%;padding:11px;background:var(--accent);border:none;color:#000;border-radius:var(--r);font-size:14px;font-weight:700;cursor:pointer;margin-top:10px;font-family:inherit;}
.setup-btn:hover{background:#ffd000;}
.setup-err{font-size:12px;color:var(--red);margin-top:8px;display:none;}

/* vacation tab */
#vac-ov .pbox{max-width:96vw;width:fit-content;}
.vac-wrap{overflow:auto;}
table.vac{border-collapse:collapse;font-size:11px;}
table.vac th,table.vac td{border:1px solid var(--border);padding:0;text-align:center;}
table.vac thead th{position:sticky;top:0;z-index:2;background:var(--card);padding:6px 7px;font-size:10px;font-weight:600;white-space:nowrap;min-width:80px;}
table.vac thead th.kw-th{position:sticky;left:0;z-index:3;min-width:44px;}
table.vac tbody td.kw-num{position:sticky;left:0;background:var(--surface);font-size:10px;color:var(--text2);padding:3px 6px;z-index:1;white-space:nowrap;}
table.vac tbody tr.cur-kw td.kw-num{color:var(--accent);font-weight:700;}
.vc{width:100%;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:background .1s;border:none;background:none;}
.vc:hover{background:var(--card2);}
.vc.marked{background:rgba(37,211,102,.18);color:var(--gi);}
.vc.marked:hover{background:rgba(37,211,102,.28);}
.vc.overlap{background:rgba(220,53,69,.18);color:var(--red);}
.vc.overlap:hover{background:rgba(220,53,69,.28);}
.vac-summary{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;font-size:11px;}
.vac-chip{padding:3px 8px;border-radius:10px;border:1px solid var(--border);background:var(--card2);color:var(--text2);}
.vac-chip.over{border-color:rgba(220,53,69,.4);color:var(--red);background:rgba(220,53,69,.1);}
.vac-chip.ok{border-color:rgba(37,211,102,.4);color:var(--gi);background:rgba(37,211,102,.08);}

.conflict-box{background:var(--card);border:1px solid var(--border2);border-radius:var(--r2);padding:18px 20px;max-width:420px;width:100%;}
.conflict-title{font-size:14px;font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:7px;}
.conflict-row{display:flex;gap:8px;margin-bottom:8px;}
.conflict-side{flex:1;background:var(--card2);border-radius:var(--r);padding:8px 10px;border:1px solid var(--border);}
.conflict-side.newer{border-color:rgba(37,211,102,.4);}
.conflict-side-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:4px;}
.conflict-side-lbl.newer{color:var(--gi);}
.conflict-detail{font-size:11px;color:var(--text2);line-height:1.7;}
